<template>
  <p>通过属性 showHeader 定义顶部插槽及工具栏是否展示</p>
  <MerakXTable
    :columns-by-store="JSON.parse(JSON.stringify(state.columns))"
    :columns="state.columns"
    :data="state.data"
    :show-header="false"
    :pagination="false"
  >
  </MerakXTable>
  <slot :html="html" />
</template>

<script setup lang="ts">
import { ref, reactive } from "vue";

import MerakXTable, { MerakXTableColumn } from "../../../../../components/MerakXTable";
import MerakIcon from "../../../../../components/MerakIcon/index.vue";

const html = ref(`
  <template>
    <div style="height: 70vh">
        <MerakXTable
            :columns-by-store="JSON.parse(JSON.stringify(state.columns))"
            :columns="state.columns"
            :data="state.data"
            :show-header="false"
            :pagination="false"
        >
        </MerakXTable>
    </div>
  </template>
  
  <script setup lang="ts">
  import { reactive } from "vue";
  
  import MerakXTable, { MerakXTableColumn } from "../../../../../components/MerakXTable";
  import MerakIcon from "../../../../../components/MerakIcon/index.vue";
  
  const state = reactive<{
    columns: MerakXTableColumn[];
    data: any[];
  }>({
    columns: [
      { field: "name", title: "Name" },
      { field: "age", title: "Age" },
      { field: "address", title: "Address" }
    ],
    data: [
      {
        id: "1",
        name: "John Brown",
        age: 32,
        address: "New York No. 1 Lake Park",
        description: "My name is John Brown, I am 32 years old, living in New York No. 1 Lake Park."
      },
      {
        id: "2",
        name: "Jim Green",
        age: 42,
        address: "London No. 1 Lake Park",
        description: "My name is Jim Green, I am 42 years old, living in London No. 1 Lake Park."
      },
      {
        id: "3",
        name: "Not Expandable",
        age: 29,
        address: "Jiangsu No. 1 Lake Park",
        description: "This not expandable"
      },
      {
        id: "4",
        name: "Joe Black",
        age: 32,
        address: "Sydney No. 1 Lake Park",
        description: "My name is Joe Black, I am 32 years old, living in Sydney No. 1 Lake Park."
      }
    ]
  });
  <\/script>
`);

const state = reactive<{
  columns: MerakXTableColumn[];
  data: any[];
}>({
  columns: [
    { field: "name", title: "Name" },
    { field: "age", title: "Age" },
    { field: "address", title: "Address" }
  ],
  data: [
    {
      id: "1",
      name: "John Brown",
      age: 32,
      address: "New York No. 1 Lake Park",
      description: "My name is John Brown, I am 32 years old, living in New York No. 1 Lake Park."
    },
    {
      id: "2",
      name: "Jim Green",
      age: 42,
      address: "London No. 1 Lake Park",
      description: "My name is Jim Green, I am 42 years old, living in London No. 1 Lake Park."
    },
    {
      id: "3",
      name: "Not Expandable",
      age: 29,
      address: "Jiangsu No. 1 Lake Park",
      description: "This not expandable"
    },
    {
      id: "4",
      name: "Joe Black",
      age: 32,
      address: "Sydney No. 1 Lake Park",
      description: "My name is Joe Black, I am 32 years old, living in Sydney No. 1 Lake Park."
    }
  ]
});
</script>
